home *** CD-ROM | disk | FTP | other *** search
/ Sprite 1984 - 1993 / Sprite 1984 - 1993.iso / src / cmds / gdb / foo / mips-opcode.h < prev    next >
Encoding:
C/C++ Source or Header  |  1991-07-02  |  13.3 KB  |  368 lines

  1. /* Mips opcde list for GDB, the GNU debugger.
  2.    Copyright (C) 1989 Free Software Foundation, Inc.
  3.    Contributed by Nobuyuki Hikichi(hikichi@sra.junet)
  4.    Made to work for little-endian machines, and debugged
  5.    by Per Bothner (bothner@cs.wisc.edu).
  6.    Many fixes contributed by Frank Yellin (fy@lucid.com).
  7.  
  8. This file is part of GDB.
  9.  
  10. GDB is free software; you can redistribute it and/or modify
  11. it under the terms of the GNU General Public License as published by
  12. the Free Software Foundation; either version 1, or (at your option)
  13. any later version.
  14.  
  15. GDB is distributed in the hope that it will be useful,
  16. but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  18. GNU General Public License for more details.
  19.  
  20. You should have received a copy of the GNU General Public License
  21. along with GDB; see the file COPYING.  If not, write to
  22. the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  23.  
  24. #ifdef BITS_BIG_ENDIAN
  25. #define BIT_FIELDS_2(a,b) a;b;
  26. #define BIT_FIELDS_4(a,b,c,d) a;b;c;d;
  27. #define BIT_FIELDS_6(a,b,c,d,e,f) a;b;c;d;e;f;
  28. #else
  29. #define BIT_FIELDS_2(a,b) b;a;
  30. #define BIT_FIELDS_4(a,b,c,d) d;c;b;a;
  31. #define BIT_FIELDS_6(a,b,c,d,e,f) f;e;d;c;b;a;
  32. #endif
  33.  
  34. struct op_i_fmt
  35. {
  36. BIT_FIELDS_4(
  37.   unsigned op : 6,
  38.   unsigned rs : 5,
  39.   unsigned rt : 5,
  40.   unsigned immediate : 16)
  41. };
  42.  
  43. struct op_j_fmt
  44. {
  45. BIT_FIELDS_2(
  46.   unsigned op : 6,
  47.   unsigned target : 26)
  48. };
  49.  
  50. struct op_r_fmt
  51. {
  52. BIT_FIELDS_6(
  53.   unsigned op : 6,
  54.   unsigned rs : 5,
  55.   unsigned rt : 5,
  56.   unsigned rd : 5,
  57.   unsigned shamt : 5,
  58.   unsigned funct : 6)
  59. };
  60.  
  61.  
  62. struct fop_i_fmt
  63. {
  64. BIT_FIELDS_4(
  65.   unsigned op : 6,
  66.   unsigned rs : 5,
  67.   unsigned rt : 5,
  68.   unsigned immediate : 16)
  69. };
  70.  
  71. struct op_b_fmt
  72. {
  73. BIT_FIELDS_4(
  74.   unsigned op : 6,
  75.   unsigned rs : 5,
  76.   unsigned rt : 5,
  77.   short delta : 16)
  78. };
  79.  
  80. struct fop_r_fmt
  81. {
  82. BIT_FIELDS_6(
  83.   unsigned op : 6,
  84.   unsigned fmt : 5,
  85.   unsigned ft : 5,
  86.   unsigned fs : 5,
  87.   unsigned fd : 5,
  88.   unsigned funct : 6)
  89. };
  90.  
  91. struct mips_opcode
  92. {
  93.   char *name;
  94.   unsigned long opcode;
  95.   unsigned long match;
  96.   char *args;
  97. };
  98.  
  99. /* args format;
  100.  
  101.    "s" rs: source register specifier
  102.    "t" rt: target register
  103.    "i" immediate
  104.    "a" target address
  105.    "c" branch condition
  106.    "d" rd: destination register specifier
  107.    "h" shamt: shift amount
  108.    "f" funct: function field
  109.  
  110.   for fpu
  111.    "S" fs source 1 register
  112.    "T" ft source 2 register
  113.    "D" destination register
  114. */
  115.  
  116. #define one(x) (x << 26)
  117. #define op_func(x, y) ((x << 26) | y)
  118. #define op_cond(x, y) ((x << 26) | (y << 16))
  119. #define op_rs_func(x, y, z) ((x << 26) | (y << 21) | z)
  120. #define op_rs_b11(x, y, z) ((x << 26) | (y << 21) | z)
  121. #define op_o16(x, y) ((x << 26) | (y << 16))
  122. #define op_bc(x, y, z) ((x << 26) | (y << 21) | (z << 16))
  123.  
  124. struct mips_opcode mips_opcodes[] = 
  125. {
  126. /* These first opcodes are special cases of the ones in the comments */
  127.   {"nop",    0,        0xffffffff,         /*li*/    ""},
  128.   {"li",    op_bc(9,0,0),    op_bc(0x3f,31,0),    /*addiu*/    "t,j"},
  129.   {"b",        one(4),        0xffff0000,         /*beq*/    "b"},
  130.   {"move",    op_func(0, 33),    op_cond(0x3f,31)|0x7ff,/*addu*/    "d,s"},
  131.  
  132.   {"sll",    op_func(0, 0),    op_func(0x3f, 0x3f),        "d,t,h"},
  133.   {"srl",    op_func(0, 2),    op_func(0x3f, 0x3f),        "d,t,h"},
  134.   {"sra",    op_func(0, 3),    op_func(0x3f, 0x3f),        "d,t,h"},
  135.   {"sllv",    op_func(0, 4),    op_func(0x3f, 0x7ff),        "d,t,s"},
  136.   {"srlv",    op_func(0, 6),    op_func(0x3f, 0x7ff),        "d,t,s"},
  137.   {"srav",    op_func(0, 7),    op_func(0x3f, 0x7ff),        "d,t,s"},
  138.   {"jr",    op_func(0, 8),    op_func(0x3f, 0x1fffff),    "s"},
  139.   {"jalr",    op_func(0, 9),    op_func(0x3f, 0x1f07ff),    "d,s"},
  140.   {"syscall",    op_func(0, 12),    op_func(0x3f, 0x3f),        ""},
  141.   {"break",    op_func(0, 13),    op_func(0x3f, 0x3f),        ""},
  142.   {"mfhi",      op_func(0, 16), op_func(0x3f, 0x03ff07ff),      "d"},
  143.   {"mthi",      op_func(0, 17), op_func(0x3f, 0x1fffff),        "s"},
  144.   {"mflo",      op_func(0, 18), op_func(0x3f, 0x03ff07ff),      "d"},
  145.   {"mtlo",      op_func(0, 19), op_func(0x3f, 0x1fffff),        "s"},
  146.   {"mult",    op_func(0, 24),    op_func(0x3f, 0xffff),        "s,t"},
  147.   {"multu",    op_func(0, 25),    op_func(0x3f, 0xffff),        "s,t"},
  148.   {"div",    op_func(0, 26),    op_func(0x3f, 0xffff),        "s,t"},
  149.   {"divu",    op_func(0, 27),    op_func(0x3f, 0xffff),        "s,t"},
  150.   {"add",    op_func(0, 32),    op_func(0x3f, 0x7ff),        "d,s,t"},
  151.   {"addu",    op_func(0, 33),    op_func(0x3f, 0x7ff),        "d,s,t"},
  152.   {"sub",    op_func(0, 34),    op_func(0x3f, 0x7ff),        "d,s,t"},
  153.   {"subu",    op_func(0, 35),    op_func(0x3f, 0x7ff),        "d,s,t"},
  154.   {"and",    op_func(0, 36),    op_func(0x3f, 0x7ff),        "d,s,t"},
  155.   {"or",    op_func(0, 37),    op_func(0x3f, 0x7ff),        "d,s,t"},
  156.   {"xor",    op_func(0, 38),    op_func(0x3f, 0x7ff),        "d,s,t"},
  157.   {"nor",    op_func(0, 39),    op_func(0x3f, 0x7ff),        "d,s,t"},
  158.   {"slt",    op_func(0, 42),    op_func(0x3f, 0x7ff),        "d,s,t"},
  159.   {"sltu",    op_func(0, 43),    op_func(0x3f, 0x7ff),        "d,s,t"},
  160.  
  161.   {"bltz",    op_cond (1, 0),    op_cond(0x3f, 0x1f),        "s,b"},
  162.   {"bgez",    op_cond (1, 1),    op_cond(0x3f, 0x1f),        "s,b"},
  163.   {"bltzal",    op_cond (1, 16),op_cond(0x3f, 0x1f),        "s,b"},
  164.   {"bgezal",    op_cond (1, 17),op_cond(0x3f, 0x1f),        "s,b"},
  165.  
  166.  
  167.   {"j",        one(2),        one(0x3f),            "a"},
  168.   {"jal",    one(3),        one(0x3f),            "a"},
  169.   {"beq",    one(4),        one(0x3f),            "s,t,b"},
  170.   {"bne",    one(5),        one(0x3f),            "s,t,b"},
  171.   {"blez",    one(6),        one(0x3f) | 0x1f0000,        "s,b"},
  172.   {"bgtz",    one(7),        one(0x3f) | 0x1f0000,        "s,b"},
  173.   {"addi",    one(8),        one(0x3f),            "t,s,j"},
  174.   {"addiu",    one(9),        one(0x3f),            "t,s,j"},
  175.   {"slti",    one(10),    one(0x3f),            "t,s,j"},
  176.   {"sltiu",    one(11),    one(0x3f),            "t,s,j"},
  177.   {"andi",    one(12),    one(0x3f),            "t,s,i"},
  178.   {"ori",    one(13),    one(0x3f),            "t,s,i"},
  179.   {"xori",    one(14),    one(0x3f),            "t,s,i"},
  180.     /* rs field is don't care field? */
  181.   {"lui",    one(15),    one(0x3f),            "t,i"},
  182.  
  183. /* co processor 0 instruction */
  184.   {"mfc0",    op_rs_b11 (16, 0, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  185.   {"cfc0",    op_rs_b11 (16, 2, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  186.   {"mtc0",    op_rs_b11 (16, 4, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  187.   {"ctc0",    op_rs_b11 (16, 6, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  188.  
  189.   {"bc0f",    op_o16(16, 0x100),    op_o16(0x3f, 0x3ff),    "b"},
  190.   {"bc0f",    op_o16(16, 0x180),    op_o16(0x3f, 0x3ff),    "b"},
  191.   {"bc0t",    op_o16(16, 0x101),    op_o16(0x3f, 0x3ff),    "b"},
  192.   {"bc0t",    op_o16(16, 0x181),    op_o16(0x3f, 0x3ff),    "b"},
  193.  
  194.   {"tlbr",    op_rs_func(16, 0x10, 1),
  195.                 op_rs_func(0x3f, 0x1f, 0x1f), ""},
  196.   {"tlbwi",    op_rs_func(16, 0x10, 2),
  197.                 op_rs_func(0x3f, 0x1f, 0x1f), ""},
  198.   {"tlbwr",    op_rs_func(16, 0x10, 6),
  199.                 op_rs_func(0x3f, 0x1f, 0x1f), ""},
  200.   {"tlbp",    op_rs_func(16, 0x10, 8),
  201.                 op_rs_func(0x3f, 0x1f, 0x1f), ""},
  202.   {"rfe",    op_rs_func(16, 0x10, 16),
  203.                 op_rs_func(0x3f, 0x1f, 0x1f), ""},
  204.  
  205.   {"mfc1",    op_rs_b11 (17, 0, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,S"},
  206.   {"cfc1",    op_rs_b11 (17, 2, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,S"},
  207.   {"mtc1",    op_rs_b11 (17, 4, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,S"},
  208.   {"ctc1",    op_rs_b11 (17, 6, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,S"},
  209.  
  210.   {"bc1f",    op_o16(17, 0x100),    op_o16(0x3f, 0x3ff),    "b"},
  211.   {"bc1f",    op_o16(17, 0x180),    op_o16(0x3f, 0x3ff),    "b"},
  212.   {"bc1t",    op_o16(17, 0x101),    op_o16(0x3f, 0x3ff),    "b"},
  213.   {"bc1t",    op_o16(17, 0x181),    op_o16(0x3f, 0x3ff),    "b"},
  214.  
  215. /* fpu instruction */
  216.   {"add.s",    op_rs_func(17, 0x10, 0),
  217.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  218.   {"add.d",    op_rs_func(17, 0x11, 0),
  219.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  220.   {"sub.s",    op_rs_func(17, 0x10, 1),
  221.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  222.   {"sub.d",    op_rs_func(17, 0x11, 1),
  223.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  224.   {"mul.s",    op_rs_func(17, 0x10, 2),
  225.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  226.   {"mul.d",    op_rs_func(17, 0x11, 2),
  227.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  228.   {"div.s",    op_rs_func(17, 0x10, 3),
  229.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  230.   {"div.d",    op_rs_func(17, 0x11, 3),
  231.                 op_rs_func(0x3f, 0x1f, 0x3f),    "D,S,T"},
  232.   {"abs.s",    op_rs_func(17, 0x10, 5),
  233.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  234.   {"abs.d",    op_rs_func(17, 0x11, 5),
  235.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  236.   {"mov.s",    op_rs_func(17, 0x10, 6),
  237.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  238.   {"mov.d",    op_rs_func(17, 0x11, 6),
  239.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  240.   {"neg.s",    op_rs_func(17, 0x10, 7),
  241.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  242.   {"neg.d",    op_rs_func(17, 0x11, 7),
  243.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  244.   {"cvt.s.s",    op_rs_func(17, 0x10, 32),
  245.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  246.   {"cvt.s.d",    op_rs_func(17, 0x11, 32),
  247.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  248.   {"cvt.s.w",    op_rs_func(17, 0x14, 32),
  249.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  250.   {"cvt.d.s",    op_rs_func(17, 0x10, 33),
  251.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  252.   {"cvt.d.d",    op_rs_func(17, 0x11, 33),
  253.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  254.   {"cvt.d.w",    op_rs_func(17, 0x14, 33),
  255.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  256.   {"cvt.w.s",    op_rs_func(17, 0x10, 36),
  257.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  258.   {"cvt.w.d",    op_rs_func(17, 0x11, 36),
  259.                 op_rs_func(0x3f, 0x1f, 0x1f003f),    "D,S"},
  260.   {"c.f.s",    op_rs_func(17, 0x10, 48),
  261.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  262.   {"c.f.d",    op_rs_func(17, 0x11, 48),
  263.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  264.   {"c.un.s",    op_rs_func(17, 0x10, 49),
  265.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  266.   {"c.un.d",    op_rs_func(17, 0x11, 49),
  267.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  268.   {"c.eq.s",    op_rs_func(17, 0x10, 50),
  269.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  270.   {"c.eq.d",    op_rs_func(17, 0x11, 50),
  271.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  272.   {"c.ueq.s",    op_rs_func(17, 0x10, 51),
  273.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  274.   {"c.ueq.d",    op_rs_func(17, 0x11, 51),
  275.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  276.   {"c.olt.s",    op_rs_func(17, 0x10, 52),
  277.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  278.   {"c.olt.d",    op_rs_func(17, 0x11, 52),
  279.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  280.   {"c.ult.s",    op_rs_func(17, 0x10, 53),
  281.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  282.   {"c.ult.d",    op_rs_func(17, 0x11, 53),
  283.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  284.   {"c.ole.s",    op_rs_func(17, 0x10, 54),
  285.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  286.   {"c.ole.d",    op_rs_func(17, 0x11, 54),
  287.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  288.   {"c.ule.s",    op_rs_func(17, 0x10, 55),
  289.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  290.   {"c.ule.d",    op_rs_func(17, 0x11, 55),
  291.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  292.   {"c.sf.s",    op_rs_func(17, 0x10, 56),
  293.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  294.   {"c.sf.d",    op_rs_func(17, 0x11, 56),
  295.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  296.   {"c.ngle.s",    op_rs_func(17, 0x10, 57),
  297.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  298.   {"c.ngle.d",    op_rs_func(17, 0x11, 57),
  299.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  300.   {"c.seq.s",    op_rs_func(17, 0x10, 58),
  301.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  302.   {"c.seq.d",    op_rs_func(17, 0x11, 58),
  303.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  304.   {"c.ngl.s",    op_rs_func(17, 0x10, 59),
  305.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  306.   {"c.ngl.d",    op_rs_func(17, 0x11, 59),
  307.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  308.   {"c.lt.s",    op_rs_func(17, 0x10, 60),
  309.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  310.   {"c.lt.d",    op_rs_func(17, 0x11, 60),
  311.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  312.   {"c.nge.s",    op_rs_func(17, 0x10, 61),
  313.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  314.   {"c.nge.d",    op_rs_func(17, 0x11, 61),
  315.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  316.   {"c.le.s",    op_rs_func(17, 0x10, 62),
  317.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  318.   {"c.le.d",    op_rs_func(17, 0x11, 62),
  319.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  320.   {"c.ngt.s",    op_rs_func(17, 0x10, 63),
  321.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  322.   {"c.ngt.d",    op_rs_func(17, 0x11, 63),
  323.                 op_rs_func(0x3f, 0x1f, 0x7ff),    "S,T"},
  324.  
  325. /* co processor 2 instruction */
  326.   {"mfc2",    op_rs_b11 (18, 0, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  327.   {"cfc2",    op_rs_b11 (18, 2, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  328.   {"mtc2",    op_rs_b11 (18, 4, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  329.   {"ctc2",    op_rs_b11 (18, 6, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  330.   {"bc2f",    op_o16(18, 0x100),    op_o16(0x3f, 0x3ff),    "b"},
  331.   {"bc2f",    op_o16(18, 0x180),    op_o16(0x3f, 0x3ff),    "b"},
  332.   {"bc2t",    op_o16(18, 0x101),    op_o16(0x3f, 0x3ff),    "b"},
  333.   {"bc2t",    op_o16(18, 0x181),    op_o16(0x3f, 0x3ff),    "b"},
  334.  
  335. /* co processor 3 instruction */
  336.   {"mtc3",    op_rs_b11 (19, 0, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  337.   {"cfc3",    op_rs_b11 (19, 2, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  338.   {"mtc3",    op_rs_b11 (19, 4, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  339.   {"ctc3",    op_rs_b11 (19, 6, 0),    op_rs_b11(0x3f, 0x1f, 0x7ff),    "t,d"},
  340.   {"bc3f",    op_o16(19, 0x100),    op_o16(0x3f, 0x3ff),    "b"},
  341.   {"bc3f",    op_o16(19, 0x180),    op_o16(0x3f, 0x3ff),    "b"},
  342.   {"bc3t",    op_o16(19, 0x101),    op_o16(0x3f, 0x3ff),    "b"},
  343.   {"bc3t",    op_o16(19, 0x181),    op_o16(0x3f, 0x3ff),    "b"},
  344.  
  345.   {"lb",    one(32),    one(0x3f),        "t,j(s)"},
  346.   {"lh",    one(33),    one(0x3f),        "t,j(s)"},
  347.   {"lwl",    one(34),    one(0x3f),        "t,j(s)"},
  348.   {"lw",    one(35),    one(0x3f),        "t,j(s)"},
  349.   {"lbu",    one(36),    one(0x3f),        "t,j(s)"},
  350.   {"lhu",    one(37),    one(0x3f),        "t,j(s)"},
  351.   {"lwr",    one(38),    one(0x3f),        "t,j(s)"},
  352.   {"sb",    one(40),    one(0x3f),        "t,j(s)"},
  353.   {"sh",    one(41),    one(0x3f),        "t,j(s)"},
  354.   {"swl",    one(42),    one(0x3f),        "t,j(s)"},
  355.   {"swr",       one(46),        one(0x3f),              "t,j(s)"},
  356.   {"sw",    one(43),    one(0x3f),        "t,j(s)"},
  357.   {"lwc0",    one(48),    one(0x3f),        "t,j(s)"},
  358. /* for fpu */
  359.   {"lwc1",    one(49),    one(0x3f),        "T,j(s)"},
  360.   {"lwc2",    one(50),    one(0x3f),        "t,j(s)"},
  361.   {"lwc3",    one(51),    one(0x3f),        "t,j(s)"},
  362.   {"swc0",    one(56),    one(0x3f),        "t,j(s)"},
  363. /* for fpu */
  364.   {"swc1",    one(57),    one(0x3f),        "T,j(s)"},
  365.   {"swc2",    one(58),    one(0x3f),        "t,j(s)"},
  366.   {"swc3",    one(59),    one(0x3f),        "t,j(s)"},
  367. };
  368.